草庐IT

time - redis:EVAL 和 TIME

全部标签

Javascript eval - 混淆?

我遇到了一些评估代码:eval('[+!+[]+!+[]+!+[]+!+[]+!+[]]');此代码等于整数5。这种东西叫什么?我试过在网上搜索,但我似乎无法弄清楚这指的是什么。我觉得这很有趣,想知道在哪里/如何学习如何打印不同的东西,而不仅仅是整数5。字母、符号等。因为我无法在该代码中指出一个模式,所以我有0成功从中获取并添加到它以产生不同的结果。这是某种混淆吗? 最佳答案 除了eval()之外,这种类型的混淆被称为非字母数字混淆。要完全非字母数字,eval必须由Array构造函数原型(prototype)函数和下标符号执行:[]

javascript - Javascript eval 的替代品

这个问题在这里已经有了答案:WhataretheAlternativestoevalinJavaScript?(11个答案)关闭7年前。Mozilla的ContentSecurityPolicy不允许使用javascripteval函数和内联脚本。他们声称eval的所有实例都可以被另一个(希望更安全的)函数替换。我同意在大多数情况下,可以替换Javascripteval,但我不确定是否可以在每种情况下进行替换。我的问题有两个:是否有通用的方法来替换每个javascripteval函数?(不一定是安全的)是否存在无法替换Javascripteval的情况?

javascript - node.js + socket.io + redis + rails — 实时应用程序

我需要向我的应用程序(RubyOnRails)添加实时性,因此,我认为更好的方法是使用node.js+socket.io+redis。我在后端(node.js)中有这个application.js文件varapp=require('http').createServer();vario=require('socket.io');varredis=require('redis').createClient();var_=require('underscore')._;io=io.listen(app);io.configure(function(){io.set("transports"

javascript - knockout JS "You cannot apply bindings multiple times to the same element"

我正在使用kendo移动应用程序构建器,我正在使用knockoutjs进行绑定(bind),但出现错误“您不能将绑定(bind)多次应用于同一元素”。我有两个包含绑定(bind)的javascript文件,在我的代码下面//Employee.js//functionEmployeeViewModel(){this.EmployeeName=ko.observable();this.EmployeeMobile=ko.observable();this.EmployeeEmail=ko.observable();}ko.applyBindings(newEmployeeViewModel

asp.net - 在 OnClientClick 代码中包含 eval/bind 值

我需要从gridview(VS2005/2008)打开一个弹出式详细信息窗口。我想要做的是在我的TemplateColumn的标记中有一个asp:Button控件,有点像这样:','','scrollbars=yes,resizable=yes,width=350,height=550');"当然,不起作用的是附加部分来设置查询字符串变量。有什么建议吗?或者是否有更好的方法来实现相同的结果? 最佳答案 我相信这样做的方法是onClientClick= 关于asp.net-在OnClien

javascript - 使用 JavaScript eval 解析 JSON

问题:我正在使用eval来解析来self的WebMethods之一的JSON返回值。我不想添加jquery-json,因为传输量已经很大了。所以我用eval解析JSON返回值。现在有传言说这是不安全的。为什么?除非他们入侵我的服务器,否则没有人可以修改JSOn返回值,在这种情况下,无论如何我都会遇到更大的问题。如果他们在本地执行,JavaScript只会在他们的浏览器中执行。所以我看不出问题出在哪里。任何人都可以使用这个具体示例阐明这一点吗?functionOnWebMethodSucceeded(JSONstrWebMethodReturnValue){varresult=eval(

javascript - 使用 eval() 在 JavaScript 中执行用户输入的安全风险

我计划为我的学生制作一个快速网页,教他们JavaScript编程。在这个页面上,我想给他们一个文本框并允许他们运行JavaScript,以便他们可以看到工作中语言的动态特性。但是,我很清楚在用户输入上使用eval()通常是一个非常糟糕的主意。发布这样的页面会带来什么样的安全风险?我应该采取哪些步骤来降低这些风险? 最佳答案 您面临的安全风险是,您从用户那里获取输入并在您网站上的脚本上下文中运行它。想象一下,如果您是一个恶意破解者,无论出于何种原因都可以完全访问修改JavaScript在网站上运行。您可以执行在您的域上运行的JavaS

javascript - 在 JavaScript 中,eval(010) 返回 8

这个问题在这里已经有了答案:NumberwithleadingzeroinJavaScript(3个答案)关闭5年前。如果我使用代码:string='010';write=eval(string);document.write(write)我在页面上写了8。为什么?即使010不是字符串,也会发生这种情况。

eval() 和附加脚本标签之间的 Javascript 区别

我想知道是否有人可以解释使用Javascript的eval()与其他方法(例如使用JQuery创建脚本标记然后将该元素附加到页面)之间的区别:eval(somecode);对比$(""+somecode+"").appendTo("head");不确定这是否相关,但这是上下文:我正在使用DrupalPopups模块的一个版本,其基本目的是通过AJAX处理整个页面请求并将其附加到模态窗口中的页面。这通常包括外部CSS和Javascript文件。为了提高所有这些AJAX加载的性能,我转而使用AJAX队列,并将外部脚本的eval()更改为所列的备选方案。但是,这会导致其他各种页面出现零星的J

javascript - 在 JavaScript 中使用 eval() 函数时如何捕获全局常量变量更改错误

我尝试检查es6中的“变量”是否常量:consta=1;functiontest(){try{a=2;//throwsanerror}catch(error){console.log(error)}}test();但是当我使用eval()函数时,它不会抛出错误。consta=1;functiontest(){try{eval("a=2;")//notthrowsanerror}catch(error){console.log(error)}}test();我将常量设置为本地常量,函数eval确实会按预期抛出错误。functiontest(){try{consta=1;eval("a=2